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SELECTABLE ANALOG FUNCTIONS ON A CONFIGURABLE DEVICE 
AND METHOD EMPLOYING NONVOLATILE MEMORY 

BACKGROUND OF THE INVENTION 

5 Field of the Invention 

The invention relates to the field of integrated circuit, and particularly to a 
configurable integrated circuit employing nonvolatile memory. 

Description of Related Art 

Power management integrated circuit market is growing rapidly for applications 

10 ranging from telecommunications, wireless devices, adaptive automotive systems, home 

appliances, to Internet security. Power management chips operate cooperatively with 

microprocessors for controlling various functions on a system. Consumer electronics, 

handheld devices, and desktop computers may require an integrated circuit to have 

different analog specifications and signal couplings with external chips. 

15 Conventional power management chips provide outputs with digital values 

without analog output capabilities. For example, many analog functions require 

transistors to operate at a higher voltage than the typically 5 volts in a digital system. 

Other conventional power management chips provide separate integrated circuit device 

for each voltage level. More recently, manufacturers trim various intemal reference 

20 voltages during wafer fabrication by burning fuses or via laser beams, which are limited 

to a one-time modification. None of these solutions are ideal due to their functional 

limitations and reduction in yield counts. 

Accordingly, it is desirable to have a power management chip that provides an 

integrated circuit with configurable analog flmctions. 
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SUMMARY OF THE INVENTION 

The invention discloses a configurable integrated circuit that enables a 
manufacturer or a customer to select the characteristics of analog functions and analog 
outputs for communication with external chips. The configurable integrated circuit 

5 employs nonvolatile (NV) memory with programmable bits including electrically 
erasable cells (E^ cells), for customizing a specific circuit configuration. Activation or 
de-assertion of NV bits trims or selects analog fimctions including internal voltage 
thresholds, reset circuits, watchdog timers, voltage sensors, bandgap, and oscillating 
fi-equencies. NV bits also control a combination of analog circuits into digital outputs, 

10 In an alternate embodiment, pin assignments on a configurable integrated circuit 

can be programmed through configuration registers. Pin assignments are directed to 
analog operations, such as programming pins to a no connect (electrically isolated), a 
watchdog timer reset input, and an active low drain output responding to a secondary 
voltage. 

15 The use of NV registers provide the capability for programming multiple times in 

altering analog fimctions and settings. For example, a mother board can be assembled 
first in which a power management chip is programmed to with a set of analog fimctions 
and settings. The reverse is also applicable. A power management chip is first inserted 
on a mother board, where resistance and capacitance values can be adjusted or substituted 

20 to attain fimctional operation. 

Optionally, the configurable integrated circuit contains actual analog circuits and 

fimctions that are selected by programming the nonvolatile memory, as opposed to a 

blank chip such as a blank ASIC. For example, the configurable integrated circuit is 
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designed to include four power management channels. If one of the four power 
management channels is not used, the unused power management channel is disabled, 
while the other three power management channels are enabled. 

Advantageously, the present invention reduces costs by trimming intemal 
voUages during a final manufacturing test or board level test of an integrated circuit chip. 
The present invention also advantageously provides a fast turnaround time by changing 
analog functions in a device configuration by programming nonvolatile memory. 
Furthermore, the present invention allows a customer to quahfy one part for use with 
different and customized apphcation, 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram illustrating a configurable microprocessor supervisory 
device with a nonvolatile memory in accordance with the present invention. 

FIG. 2 is a flow chart illustrating the configurable microprocessor supervisory 
device with a nonvolatile memory in accordance with the present invention. 

FIGS. 3A-3D are table diagrams illustrating bit assignments for bytes 0 through 3 
in configuration registers in a configurable microprocessor supervisory device in 
accordance with the present invention. 

FIG. 4 is a diagram illustrating an altemate embodiment in a configurable 
microprocessor supervisory device for programming pin assignments in accordance with 
the present invention. 

FIG. 5 is a block diagram in combining analog outputs to generate a digital output 
in accordance with the present invention, 
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DETAILED DESCRIPTION OF PREFERRED EMBODIMENT 

FIG. 1 is an architectural diagram of a configurable microprocessor supervisory 
device 10 which employs a nonvolatile (NV) memory 11. Configurable microprocessor 
supervisory device 10 includes NV memory 11 having configuration registers 12-15, an 

5 x-to-y decoder 16, a first configuration 17, a second configuration 18, a third 
configuration 19, and an n configuration 20. Configurable microprocessor supervisory 
device 10 provides a range of analog functions and output levels which are selectable by 
programming the bits in NV register 12, 13, 14, and 15. Decoder 16 decodes through a 
hne 21 of programmable bits in configuration register 12, a line 22 of programmable bits 

10 in configuration register 13, a line 23 of programmable bits in configuration register 14, 
or a line 24 of programmable bits in configuration register 15. The result of decoding 
configuration registers 12-15 produces a device configuration as either first configuration 
17 via a line 25, second configuration 18 via a line 26, third configuration 19 via a hne 
27, and n configuration 20 via a line 28. 

15 A manufacturer or user initially determines a desirable set of analog fimctions in 

configurable microprocessor supervisory device 10. Configurable microprocessor 
supervisory device 10 then becomes one of the configurations as first configuration 16, 
second configuration 17, third configuration 18, or n configuration 19. The configuration 
in microprocessor supervisory device 10 is determmed by the programmable bits in NV 

20 registers 13, 14, and 15. Each bit or a combination of bits in NV registers 13, 14, and 15 
corresponds to activating or deactivating an analog fimction, or increasing or decreasing 
an activated analog fimction. Optionally, one skilled in the art should recognize that 
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digital functions, or a combination of digital and analog functions can be integrated on 
configurable microprocessor supervisory device 10 for selection by NV registers 12-15, 

FIG. 2 is a flow chart of configurable microprocessor supervisory method 20 with 
non- volatile memory 11. A manufacturer or user selects 31 a certain combinations of 

5 analog functions and output levels for operation with a microprocessor (not shown). The 
combination of analog functions and output levels corresponds with first configuration 
17, second configuration 18, third configuration 19, or n configuration 20. A 
manufacturer or user programs 32 certain nonvolatile bits in configuration registers 12, 
13, 14, and 15 which correspond and enable the selected combinations of analog 

10 functions and output levels. An analog function or output level may have a range of 
settings. Optionally, when an analog function is enabled in step 32, the manufacturer or 
user programs 33 nonvolatile bits in configuration registers 12, 13, 14, and 15 to set a 
specific analog value associated with that enabled analog function. As a resuU of 
selecting the desirable combination of analog functions by programming configuration 

15 registers 12-15, first configuration 17, second configuration 18, third configuration 19, or 
n configuration 20 is generated on configurable microprocessor supervisory device 10. 

FIGS. 3A-3D are table diagrams that illustrates one embodiment of configurable 
microprocessor supervisory device 10 with four configuration registers. Each NV 
registers corresponds to a specified byte, namely, configuration register 12 storing byte 0, 

20 configuration register 13 storing byte 1, configuration register 14 storing byte 2, and 

configuration register 15 storing byte 3. 

FIG. 3 A is a table diagram showing bit assignments of byte 0 of configuration 

register 12. The reset voltage range on configurable microprocessor supervisory device 
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10 is selected by programming bits 4-0 in byte 0. Depending on the binary value of 
byteo[4:0] in configuration register 12, a corresponding reset voltage is selected. More 
specifically, the reset voltage is set as follows: if byteo[4:0] is programmed with a binary 
value of "10000", "01000", "00100", "00010", and "00001", the reset voltage is set 

5 respectively to 4.625, 4.375, 2.9, 2.65, and 2.15 volts. The duration of a reset timeout on 
configurable microprocessor supervisory device 10 is progranraiable through the 
selection in bits 5 and 6 in byte 0. The reset timeout is set at 200ms when byteo[6:5] = 
"11", set at 100ms when byteo[6:5] = 10, set at 50ms when byteo[6:5] = "01", and set at 
25ms when byteo[6:5] = "00". 

10 FIG. 3B is a table diagram showing the bit assignments of byte 1 of configuration 

register 13. Byte 1 contains NV bits for selecting write enable, V^^nse voltage, responding 
to all addresses, device identifier code, and watchdog interval. The duration of a 
watchdog interval is programmable through bits 2-0 in byte 1. When bytei[2:0] is 
programmed as "111", "110", "101", "100", "Oil" in binary value, the corresponding 

15 watchdog interval is equal to 6.4 seconds, 3.2 seconds, 1.6 seconds, 0.8 second, and 0.4 
seconds respectively. The watchdog timer is in an OFF state when bytei[2:0] = OOX. A 
device identifier code is selected by programming bit 3 in byte 1 such that the device is 
responds to "1011" if bytei[3] is programmed with a "1" and responds to "1010" if 
bytei[3] is programmed with a "0". 

20 Bit 4 of byte 1 in configuration register 13 designates whether configurable 

microprocessor supervisory device 10 responds to all addresses or responds to pin 
addresses. Configurable microprocessor supervisory device 10 responds to all addresses 
if byte2[4] = "1" and responds to all pin addresses if byte2[4] = "0". Table 1 below fiirther 
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shows the designation of bit 4 for each of the eight parts in this embodiment. Bit 5 of 
byte 1 of configuration register 13 indicates whether is undervoltage or overvoltage. 
V,e„se is undervoltage when byte2[5] = "1" while is overvoltage when byte2[5] = "1". 
Bit 6 of byte 1 turns ON or OFF A complete configuration write enable signal. The write 
enable signal is disabled if byte2[6] = "1" and is enabled if byte2[6] = "0". 



Table 1 



Part No. 


Byte 1: bit 4 


Other Functions 


Part 1 


Set low to respond to pin addresses. 


Pin 7 has an 
internal pulldown 
on this pin. This 
pin may float or tie 
low. 


Part 2 


Set high to respond to all addresses. If byte 
1 :bit 4 is set low, then the part responds to 
Al on pinl and A2 on pin 3. AO is a don't 
care. 




Parts 


Set high to respond to all addresses. If byte 
1 :bit 4 is set low, then the part will respond 
to Al on pinl and A2 on pin3. AO is a 
don't care. 




Part 4 


Set high to respond to all addresses. If 
bytel:bit4 is set low, then this part 
responds to A2 on pin3. AO and Al are 
don't care. 




Parts 


Set high to respond to all addresses. 


Both resets respond 
to Vcc low, 
RESETNJn, and 


Part 6 


Respond to all addresses regardless of the 
setting ofbytel:bit4. 




Part? 


Respond to all addresses regardless of the 
setting ofbytel:bit 4. 




Parts 


Set low to respond to pin addresses. 





FIG. 3C is a table diagram showing the bit assigimients of byte 2 of configuration 
register 14. Byte 2 includes programmable bits for trimming the Vg^nse voltage or 
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bandgap, for trimming the frequency of an oscillator, or for selecting whether to utilize 
fiill or half memory capacity. The V^^nse voltage is trimmed by programming bits 3-0 of 
byte 2 of configuration register 14 where the Y,,^^ voltage is trimmed to a lower value if 
byte3[3:0] = "1111" while the W,^, voltage is increased to a higher value if byte3[3:0] = 
5 "0000". The trimming of the voltage can be an iterative process in which the 
voltage trimming is repeated imtil the desirable Y,^ voltage is attained. The allocation 
of full or half memory is programmable through bit 4 of byte 2. Full memory is utilized 
when byte3[4] = "1" and only half memory is utilized when byte3[4] = "0". In this 
illustration, although 4K or 16K represents a full memory while 2K or 8K represents half 
10 memory, one skilled in the art should recognize that the value of full or half memory 
capacity can be adjusted depending a designer's choice. The oscillator's frequency is 
trimmed by programming bits 7-5 in byte 2 in configuration register 14. The frequency 
of the oscillator is reduced if byte3[7-5] = "111". To increase the frequency of the 
oscillator, the value of byte3[7-5] is set to "000". Similarly, this process can be repeated 
15 to fiirther decrease or increase the frequency setting of the oscillator until a desirable 
frequency is obtained. 

FIG. 3D is a table diagram showing bit assignments of byte 3 of configuration 
register 15. Byte 3 includes programming bits for trimming a V^p voltage, for selecting a 
frill or half memory, and for enabling a configuration write disable signal. The V^p 
20 voltage is trimmed by setting byte4[3:0] = "1111". To increase the Y^^^ voltage, 
byte4[3:0] are set to "0000". This process can be repeated to fiirther decrease or increase 
the V^p voltage until the desirable Voip voltage is reached. Bits 6-4 in byte 3 of 
configuration register 15 select fiiU or half memory for a particular configuration. When 
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byte4[6:4] = "111", the full/half memory for a part 8 or an eighth configuration is 
selected. . When byte4[6:4] = "110", the Ml/half memory for a part 7 or a seventh 
configuration is selected. When byte4[6:4] = "101", "100", "Oil", "010", "001", and 
"000", the full/half memory is respectively selected for a part 6 or a sixth configuration, a 
5 part 5 or a fifth configuration, a part 4 or a fourth configuration, a part 3 or third 
configuration 19, a part 2 or second configuration 18, and part 1 or first configuration 17. 
The configuration write disable signal is programmed through bit 7 in byte 3 of 
configuration register 15 where the configuration write enable is enabled if byte4[7] = "0" 
and the configuration write enable is disabled when byte4[7] = "1". Additional registers 
10 divided as tiim registers and as configuration registers are illustrated in hexadecimal 
numbers in Appendixes A and B. 

In an alternate embodiment, configuration registers in NV memory 11 are used to 
designate pin assignments. Configurable microprocessor supervisory device 10 is a 
configurable integrated circuit with eight pins which can be programmed to operate as 
15 one of the eight parts. The pin assignments for device 10 is configured as follows: if 
programmed as part 1, then pins 1 through 8 are assigned with pin 1 as NC, pin 2 as 
RESET#, pin 3 as NC, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as RESET, and 
pin 8 as VCC; if programmed as part 2, then pins 1 through 8 are assigned with pin 1 as 
NC, pin 2 as RESET#, pin 3 as NC, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as 
20 NC, and pin 8 as VCC; if programmed as part 3, then pins 1 through 8 are assigned with 
pin 1 as AO, pin 2 as Al, pin 3 as A2, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as 
NC, and pin 8 as VCC; if programmed as part 4, then pins 1 through 8 are assigned with 
pin 1 as WDI, pin 2 as RESET#, pin 3 as NC, pm 4 as Gnd, pin 5 as SDA, pin 6 as SCL, 
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pin 7 as RESET, and pin 8 as VCC; if programmed as part 5, then pins 1 through 8 are 
assigned with pin 1 as VLOW, pin 2 as RESET#, pin 3 as VSENSE, pin 4 as Gnd, pin 5 
as SDA, pin 6 as SCL, pin 7 as RESET, and pin 8 as VCC; if programmed as part 6, then 
pins 1 through 8 are assigned with pin 1 as RESET#2, pin 2 as RESET#, pin 3 as 
VSENSE, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as MR#, and pin 8 as VCC; if 
programmed as part 7, then pins 1 through 8 are assigned with VLOW#, pin 2 as RESET, 
pin 3 as VSENSE, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as WDI, and pin 8 as 
VCC; if programmed as part 8, then pins 1 through 8 are assigned with pin 1 as AO, pin 2 
as Al, pin 3 as A3, pin 4 as Gnd, pin 5 as SDA, pin 6 as SCL, pin 7 as RESET#, and pin 
8 as VCC. Table 2 below further shows the pin assignments as described in FIG. 4. 



Table 2 



Pm# 


Parts 


Part? 


Part 6 


Parts 


Part 4 


Parts 


Part 2 


Part 1 


1 


AO 


Al 


Al 


WDIB 


RESETB 1 


VLOWB 


VLOWB 


AO 


2 


Al 


RESETS 


RESETB 


RESETB 


RESETB2 


RESETB 


RESETB 


Al 


3 


A2 


A2 


A2 


A2 


VSENSE 


VSENSE 


VSENSE 


A2 


4 


GND 


GND 


GND 


GND 


GND 


GND 


GND 


GND 


5 


SDA 


SDA 


SDA 


SDA 


SDA 


SDA 


SDA 


SDA 


6 


SCL 


SCL 


SCL 


SCL 


SCL 


SCL 


SCL 


SCL 


7 


NC 


NC/RESET 


WP 


RESET 


RESETB_ 
in 


WDI 


WDI 


RESETB 


8 


VCC 


VCC 


VCC 


VCC 


VCC 


VCC 


VCC 


VCC 



Various control settings and modifications of configuration registers 12-15 are 
within the spirit of the present invention. For example, configuration registers 12-15 can 
be set at the factory and then locked so that a user just receives a standard part and is not 
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aware that the part is programmable. Or, two configuration registers 12 and 13 can be 
accessed by a user with the other two configuration registers 14 and 15 are locked. Or, all 
four configuration registers 12-15 can be accessed by the user and then locked if the user 
choose to trim analog functions and to select a device interface among multiple possible 
interfaces. 

FIG. 5 is a block diagram 40 in combining multiple analog outputs in generating a 
digital output. The block diagram 40 is integrated in configurable microprocessor 
supervisory device 10 and includes an analog subcircuit 41, an analog subcircuit 42, an 
analog subcu-cuit 43, and a logic gate 44. Logic gate 44, such as an OR gate or an AND 
gate, receives an analog output 45, an analog output 46, and an analog output 47 for 
generate a digital output 48. An example of digital output 48 is an interrupt request 
signal, IRQ#, which collects from various analog signals to produce the rR.Q# signal. 

The above embodiments are only illustrative of the principles of this invention 
and are not intended to hmit the invention to the particular embodiments described. For 
example, it is apparent to one skilled in the art that nonvolatile memory 11 can include as 
many configuration registers as needed to program various combinations of analog 
functions, digital functions, pin assignments, internal voltages, and external voltages. 
Moreover, one skilled in the art should recognize that a device configuration caii be made 
dynamic such that an integrated circuit device can be re-configured during each power up 
or by the reception of an external control signal. Accordingly, various modifications, 
adaptations, and combinations of various features of the described embodiments can be 
practiced without departing from the scope of the invention as set forth m the appended 
claims. 
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APPENDIX A 
Unpublished © 1999, Summit Microelectronics, Inc. 

Trim Bit Description 

Register Assignments 

0 7-4 Not used 

3 Configuration Write Disable 

XXXX IXXX Write Disable 
XXXX OXXX Write Enable 

2- 0 Oscillator Trim 

XXXX XI 11 Slower 
XXXX XOOO Faster 

1 7-5 Not Used 

4-0 Slew Rate Trim 

XXXI nil Faster 
XXXO 0000 Slower 

2 7-4 Temp Comp TIR Current Trim 

nil XXXX Higher 
0000 XXXX Lower 

3- 0 Flat Across Temp Current Trim 

XXXX nil Higher 
XXXX 0000 Lower 

3 7-4 Temp Comp Amp Gain Trim 

nil XXXX Higher 
0000 XXXX Lower 

3-0 Bandgap Trim 

XXXX nil Lower 
XXXX 0000 Higher 

4 7-0 Temp Sense Amp Trim 

nil nil Higher 
0000 0000 Lower 

5 7-6 CB_D Trip Adjustment 

IIXX XXXX Higher 
OOXX XXXX Lower 

5-4 CB C Trip Adjustment 
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XXI IXXXX Higher 
XXOOXXXX Lower 



3- 2 CB_B Trip Adjustment 

XXXXllXX Higher 
XXXX OOXX Lower 

1 -0 CB_A Trip Adjustment 
XXXX XXI 1 Higher 
XXXXXXOO Lower 

7-5 Not Used 

4- 0 Tamp Offset Trim 

XXI 1 nil Higher 
XXOO 0000 Lower 

7-0 Overvoltage/Undervoltage2 Current Trim 
1111 1111 Higher 
0000 0000 Lower 
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APPENDIX B 
Unpublished © 1999, Summit Microelectronics, Inc. 

Configuration Bit Description 

Register Assignments 

0 7-0 Bus side A undervoltage trip point 

nil nil higher 
0000 0000 lower 

1 7-0 Bus side B undervoltage trip point 

nil nil higher 
0000 0000 lower 

2 7-0 Bus side C undervoltage trip point 

nil nil higher 
0000 0000 lower 

3 7-0 Bus side D undervoltage trip point 

nil nil higher 
0000 0000 lower 

4 7 Bus side A vindervoltage enable 

IXXXX XXXX enable 
OXXXX XXXX disable 

6 Bus side A overvoltage enable 

XIXX XXXX enable 
XOXX XXXX disable 

5-0 Bus side A overvoltage offset 
XXll nil higher 
XXOO 0000 lower 

5 7 Bus side B undervoltage enable 

IXXXX XXXX enable 
OXXXX XXXX disable 

6 Bus side B overvoltage enable 

XIXX XXXX enable 
XOXX XXXX disable 

5-0 Bus side B overvoltage offset 
XXll nil higher 
XXOO 0000 lower 
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Bus side C undervoltage enable 
7 IXXXX XXXX enable 

OXXXXXXXX disable 

6 Bus side B overvoltage enable 
XIXX XXXX enable 
XOXX XXXX disable 

5-0 Bus side B overvoltage offset 
XXI 1 nil higher 
XXOO 0000 lower 
Bus side D undervoltage enable 

7 IXXXX XXXX enable 
OXXXX XXXX disable 

6 Bus side B overvoltage enable 
XIXX XXXX enable 
XOXX XXXX disable 

5-0 Bus side B overvoltage offset 
XXll 1111 higher 
XXOO 0000 lower 

7-0 Card side A undervoltage trip point 
nil nil higher 
0000 0000 lower 

7-0 Card side B undervoltage trip point 
nil nil higher 
0000 0000 lower 

7-0 Card side C undervoltage trip point 
nil nil higher 
0000 0000 lower 

7-0 Card side D undervoltage trip point 
nil nil higher 
0000 0000 lower 

7 Not used 

6 Soft start enable supply A 

XIXX XXXX enable 
5-0 XOXX XXXX disable 
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Card side A overvoltage offset 
XXI 1 nil higher 
XXOO 0000 lower 



D 7 Not used 



6 Soft start enable supply B 
XIXXXXXX enable 
XOXX XXXX disable 

5-0 Card side A overvoltage offset 
XXI 1 nil higher 
XXOO 0000 lower 
E 7 Not used 

Soft start enable supply C 
6 XIXX XXXX enable 

XOXX XXXX disable 

5-0 

Card side A overvoltage offset 
XXI 1 nil higher 
XXOO 0000 lower 
F 7 Not used 

6 Soft start enable supply D 

XIXX XXXX enable 
XOXX XXXX disable 

5-0 Card side A overvoltage offset 
XXll nil higher 
XXOO 0000 lower 

10 7 Responds to all addresses 

IXXX XXXX respond to all addresses 
OXXX XXXX respond to pin addresses 

6 Change deAdce identifier code 
XIXX XXXX respond to 101 1 
XOXX XXXX respond to 1 01 0 

5-4 Tracker over/under 300mv action 
XXI 1 XXXX generate IRQ 
XXIO XXXX shut down all 
XXOl XXXX shut down bad channel 
XXOO XXXX do nothing 
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3-2 Tracker slew rate rising 
XXXXllXXlOOOv/s 
XXXX lOXX 500 v/s 
XXXX01XX250v/s 
XXXX OOXX 100 v/s 

1 -0 Tracker slew rate falling 
XXXX IIXX 1000 v/s 
XXXX lOXX 500 v/s 
XXXX OIXX 250 v/s 
XXXX OOXX 100 v/s 

11 7 Bus side A imdervoltage 

IXXX XXXX triggers reset 
OXXX XXXX does not trigger reset 

6 Bus side B undervoltage 

XIXX XXXX triggers reset 
XOXX XXXX does not trigger reset 

5 Bus side C undervoltage 

XXIX XXXX triggers reset 
XXOX XXXX does not trigger reset 

4 Bus side D undervoltage 

XXXI XXXX triggers reset 
XXXO XXXX does not trigger reset 

3 Bus side A overvoltage 

XXXX IXXX triggers reset 
XXXX OXXX does not trigger reset 

2 Bus side B overvoltage 

XXXX XIXX triggers reset 
XXXX XOXX does not trigger reset 

1 Bus side C overvoltage 

XXXX XXIX triggers reset 
XXXX XXOX does not trigger reset 

0 Bus side D overvoltage 

XXXX XXXI triggers reset 
XXXX XXXO does not trigger reset 



NV Memory 



-18- 



SUMT-POOl 



12 7 Card side A undervoltage 

IXXX XXXX triggers reset 
OXXX XXXX does not trigger reset 

6 Card side B undervoltage 

XIXX XXXX triggers reset 
XOXX XXXX does not trigger reset 

5 Card side C undervoltage 
XXIX XXXX triggers reset 
XXOXX XXXX does not trigger reset 

4 Card side D undervoltage 
XXXI XXXX triggers reset 
XXXO XXXX does not trigger reset 

3 Card side A iindervoltage#2 
XXXX IXXX triggers reset 
XXXX OXXX does not trigger reset 

2 Card side B undervoltage#2 
XXXX XIXX triggers reset 
XXXX XOXX does not trigger reset 

1 Card side C undervoltage#2 

XXXX XXIX triggers reset 
XXXX XXOX does not trigger reset 

0 Card side D undervoltage#2 

XXXX XXXI triggers reset 
XXXX XXXO does not trigger reset 

13 7 Bus side A undervoltage 

IXXX XXXX triggers IRQ# 
OXXX XXXX does not trigger IRQ# 

6 Bus side B undervoltage 
XIXX XXXX triggers IRQ# 
XOXX XXXX does not trigger IRQ# 

5 Bus side C undervoltage 
XXIX XXXX triggers IRQ# 
XXOX XXXX does not trigger IRQ# 

4 Bus side D undervoltage 
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XXXI XXXX triggers IRQ# 
XXXO XXXX does not trigger IRQ# 



3 Bus side A overvoltage 
XXXX IXXX triggers IRQ# 
XXXX OXXX does not trigger IRQ# 

2 Bus side B overvoltage 
XXXX XIXX triggers IRQ# 
XXXX XOXX does not trigger IRQ# 

1 Bus side C overvoltage 
XXXX XXIX triggers IRQ# 
XXXX XXOX does not trigger IRQ# 

0 Bus side D overvoltage 
XXXX XXXI triggers IRQ# 
XXXX XXXO does not trigger IRQ# 

14 7 Card side A undervoltage 

IXXX XXXX triggers IRQ# 
OXXX XXXX does not trigger IRQ# 

6 Card side B undervoltage 

XIXX XXXX triggers IRQ# 
XOXX XXXX does not trigger IRQ# 

5 Card side C undervoltage 

XXIX XXXX triggers IRQ# 
XXOX XXXX does not trigger IRQ# 

4 Card side D undervoltage 
XXXI XXXX triggers IRQ# 
XXXO XXXX does not trigger IRQ# 

3 Card side A undervoltage#2 
XXXX IXXX triggers IRQ# 
XXXX OXXX does not trigger IRQ# 

2 Card side B undervoltage#2 
XXXX XIXX triggers IRQ# 
XXXX XOXX does not trigger IRQ# 

1 Card side C undervoltage#2 
XXXX XXIX triggers IRQ# 
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XXXX XXOX does not trigger IRQ# 



0 Card side D undervoltage#2 
XXXX XXXI triggers IRQ# 
XXXX XXXO does not trigger IRQ# 

15 7 Bus side A undervoltage IRQ# fault (volatile) 

IXXX XXXX fault 
OXXX XXXX no fault 

6 Bus side B undervoltage IRQ# fault (volatile) 

XIXX XXXX fault 
XOXX XXXX no fault 

5 Bus side C undervoltage IRQ# fault (volatile) 
XXIX XXXX fault 

XXOX XXXX no fault 

4 Bus side D undervoltage IRQ# fault (volatile) 

XXXI XXXX fault 
XXXO XXXX no fault 

3 Bus side A overvoltage IRQ# fault (volatile) 

XXXX IXXX fault 
XXXX OXXX no fault 

2 Bus side B overvoltage IRQ# fault (volatile) 

XXXX XIXX fault 
XXXX XOXX no fault 

1 Bus side C overvoltage IRQ# fault (volatile) 
XXXX XXIX fault 

XXXX XXOX no fault 

0 Bus side D overvoltage IRQ# fault (volatile) 

XXXX XXXI fault 
XXXX XXXO no fault 

16 7 Card side A undervoltage IRQ# fault (volatile) 

IXXX XXXX fault 
OXXX XXXX no fault 

6 Card side B undervoltage IRQ# fault (volatile) 
XIXX XXXX fault 

XOXX XXXX no fault 
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Card side C undervoltage IRQ# fault (volatile) 
XXIX XXXX fault 
XXOXXXXX no fault 

Card side D undervoltage IRQ# fault (volatile) 
XXXI XXXX fault 
XXXO XXXX no fault 

Card side A overvoltage IRQ# fault (volatile) 
XXXX IXXX fault 
XXXX OXXX no fault 

Card side B overvoltage IRQ# fault (volatile) 
XXXX XIXX fault 
XXXX XOXX no fault 

Card side C overvoltage IRQ# fault (volatile) 
XXXX XXIX fault 
XXXX XXOX no fault 

Card side D overvoltage IRQ# fault (volatile) 
XXXX XXXI fault 
XXXX XXXO no fault 



17 7-6 Unused 



5-3 Long dog 

XXll IXXX 6.4ms 
XXll OXXX 3.2ms 
XXIO IXXX 1.6ms 
XXIO OXXX 0.8ms 
XXOX XXXX off 

2-0 XXXX Xll 13.2s 
XXXXXllO 1.6s 
XXXXXlOl 0.8s 
XXXX XlOO 0.4s 
XXXX XOXX off 



NV Memory 



-22- 



SUMT-POOl 



We Claim: 

1 LA method for programming a configurable integrated circuit, comprising the 

2 steps of: 

3 programming a pluraHty of nonvolatile bits in one or more nonvolatile registers, 

4 each nonvolatile bit or a combination of nonvolatile bits in the plurality of nonvolatile 

5 bits corresponding to an analog function; and 

6 generating a configuration on an integrated circuit from programming the plurality 

7 of nonvolatile bits in the one or more nonvolatile registers. 

1 2. The method of Claim 1 wherein the plurahty of nonvolatile bits in the one or 

2 more nonvolatile registers comprises cells. 

1 3. The method of Claim 1 wherein in the programming step comprises the step 

2 of enabling an analog function by the nonvolatile bit or the combination of nonvolatile 

3 bits. 



1 4. The method of Claim 3 wherein in the enabling step comprises the step of 

2 setting the analog function to a specific value. 

1 5. The method of Claim 1 wherein in the programming step comprises changing 

2 pin assignments by programming one or more nonvolatile bits. 
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1 6. The method of Claim 1 wherein the analog function comprises trimming an 

2 internal voltage of the integrated circuit. 



1 7. The method of Claim 1 further comprising the step of combining a plurality of 

2 analog signals to generate a digital output. 

1 8. The method of Claim 1 further comprising the step of storing a status of a 

2 fault condition of the integrated circuit in the one or more NV registers. 



1 9. An integrated circuit, comprising: 

2 one or more nonvolatile registers having a plurality of nonvolatile bits, each 

3 nonvolatile bit or a combination of nonvolatile bits in the plurality of nonvolatile bits 

4 corresponding to programming an analog function; and 

5 a circuit configuration in the integrated circuit being generated from programming 

6 one or more nonvolatile registers. 



1 10. The integrated circuit of Claim 9 further comprising a decoder, coupled 

2 between the one or more nonvolatile registers and a circuit configuration, for decoding 

3 the plurality of nonvolatile bits for progranmiing analog functions. 
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1 IL The integrated circuit of Claim 9 wherein the pluraUty of nonvolatile bits 

2 comprises cells. 



1 12. The integrated circuit of Claim 9 wherein the nonvolatile bit or the 

2 combination of nonvolatile bits in the one or more nonvolatile registers enables the 

3 analog function. 

1 13. The integrated circuit of Claim 12 wherein the nonvolatile bit or the 

2 combination of nonvolatile bits in the one or more nonvolatile registers sets a specific 

3 value to the enabled analog function. 

4 14. The integrated circuit of Claim 9 wherein the nonvolatile bit or the 

5 combination of nonvolatile bits in the one or more nonvolatile registers changes pin 

6 assignments of the integrated circuit. 



1 15, The integrated circuit of Claim 12 where the bit or the combination of 

2 nonvolatile bits trims an internal voltage of the enabled analog function. 

1 16. The integrated circuit of Claim 9 further comprising a logic gate for 

2 combining a plurality of analog signals to generate a digital output. 
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1 17, A configurable device, comprising: 

2 means for programming one or more nonvolatile registers having a plurality of 

3 nonvolatile bits, each bit or a combination of bits in the plurality of nonvolatile bits 

4 corresponding to an analog function; and 

5 means for generating a configuration from programming the plurality of 

6 nonvolatile bits. 

1 18. The configurable device of Claim 17 wherein the programming means of the 

2 one or more nonvolatile registers comprises cells. 

1 19. The configurable device of Claim 17 wherein the programming means 

2 comprises enabling the analog function. 

1 20. The configurable device of Claim 17 wherein the programming means 

2 comprises selecting a specific value of the analog function. 
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ABSTRACT 



A configurable integrated circuit and method for 
trimming a desirable combination of analog and digital 
5 functions and customizing pin assignments by 

programming nonvolatile memory. Functional 
enhancement and chip compatibility are achieved by 
configuring an integrated circuit with specified analog and 
digital settings for operation with an extemal chip. 
10 Multiple NV registers with designated bits that correspond 

to activating, deactivating, trimming, or changing analog 
fimctions including internal voltages, bandgap, and 
oscillating fi*equencies. 
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